{{tag>console terminal shell aide manuel BROUILLON}}
-----

====== Le manuel ======

**man**((qui abrège **man**uel, en anglais **man**ual)) est une commande UNIX permettant d'accéder aux pages de manuel installées sur le système.
La plupart des programmes fournissent une page de manuel les documentant, lisible donc avec la commande ''man''.

===== Installation =====
Aucune installation n'est nécessaire, man est installé par défaut sous Ubuntu (toutes versions). Vous pouvez cependant ajouter des pages de manuel supplémentaires en [[:tutoriel:comment_installer_un_paquet|installant le paquet]] correspondant.

==== Pages de manuel supplémentaires ====
  * **[[apt://manpages-fr|manpages-fr]]** : Version française des pages de manuel sur l'utilisation de GNU/Linux
  * **[[apt://manpages-fr-extra|manpages-fr-extra]]** : Version française des pages de manuel des programmes
  * **[[apt://manpages|manpages]]** : Pages de manuel (en anglais) sur l'utilisation de GNU/Linux
  * **[[apt://manpages-posix|manpages-posix]]** : Pages de manuel (en anglais) sur l'utilisation des systèmes POSIX
=== Pour le développeur ===
  * **[[apt://manpages-fr-dev|manpages-fr-dev]]** : Version française des pages de manuel pour les développeurs
  * **[[apt://manpages-dev|manpages-dev]]** : Pages de manuel (en anglais) pour les développeurs
  * **[[apt://manpages-posix-dev|manpages-posix-dev]]** : Pages de manuel (en anglais) sur l'utilisation des systèmes POSIX pour les développeurs
=== Autres ===
  * **[[apt://funny-manpages|funny-manpages]]** : Pages de manuel humoristiques (en anglais)

===== Utilisation =====

''man'' s'utilise dans un [[terminal]] de la façon suivante :
  man nom-de-la-page
Par exemple, pour obtenir le manuel de la commande ''man'', l'on fera :
  man man

==== Les sections ====

Les pages de manuel sont réparties dans des sections distinctes :
  - Programmes exécutables ou commandes de l'interpréteur de commandes ([[shell]]) ;
  - Appels système (Fonctions fournies par le noyau) ;
  - Appels de bibliothèque (fonctions fournies par des bibliothèques) ;
  - Fichiers spéciaux (situés généralement dans /dev) ;
  - Formats des fichiers et conventions (Par exemple ''/etc/passwd'') ;
  - Jeux ;
  - Divers (y compris les macropaquets et les conventions). Par exemple, man(7), groff(7) ;
  - Commandes de gestion du système (généralement réservées au [[superutilisateur]]) ;
  - Interface du noyau Linux.
Les numéros de sections sont souvent spécifiés entre parenthèses après le nom de la page, comme ci-dessus.

Il arrive (rarement) que deux pages de manuel aient le même nom mais soient dans des sections différentes ; c'est le cas de man(1) et man(7) ou de printf(1) et printf(3) par exemple. Il est donc possible de spécifier dans quelle section chercher la page de manuel, en indiquant son numéro juste avant le nom de la page ou en spécifiant le paramètre ''-s'' (voir [[#options utiles|ci-dessous]]). Par exemple, pour obtenir la page de manuel de man(7) (qui parle de la syntaxe des pages de manuel), l'on fera :
  man 7 man

Chaque section possède de plus une page appelée ''intro'' qui présente la section, accessible comme les autres pages de manuel. Pour lire l'introduction de la section 3, il suffit donc de saisir :
  man 3 intro

==== Options utiles ====

  * **-L LANGUE** : permet de spécifier la [[wpfr>Paramètres régionaux|locale]] pour laquelle afficher la page de manuel. Cette locale est par défaut celle du système.\\ Par exemple, afficher la page de manuel de [[man]] en anglais : <code>man -L en man</code>
  * **-s SECTION** : permet de spécifier la ou les sections où chercher, dans l'ordre, les pages de manuel. SECTION est un numéro de section ou une liste de numéros de sections séparées par des virgules.\\ Exemple :<code>man -s 3 printf</code>

==== Interactivité ====

Lorsque une page de manuel est affichée, diverses actions sont accessibles //via// des raccourcis claviers dont voici un court extrait((Certaines commandes comme ''?'' ou ''N'' ne sont disponibles qu'avec certains //pageurs//. Néanmoins, le //pageur// par défaut devrait les supporter.)) :
^ Raccourci ^ Action ^
| flèches directionnelles | Navigation dans la page de manuel |
| ''q''                   | Quitte |
| ''h''                   | Affiche l'aide |
| ''/''                   | Rechercher en avant. Entrez le //pattern// à recherchez et validez avec la touche entrée |
| ''?''                   | Comme ''/'', mais recherche en arrière |
| ''n''                   | Va à l'occurrence suivante de la recherche |
| ''N''                   | Va à l'occurrence précédente de la recherche |


===== Consulter les pages de manuel dans une interface graphique =====

==== Sous GNOME (Ubuntu) ====

Le [[yelp|navigateur d'aide]] de [[GNOME]] permet de parcourir la documentation du système, dont les pages de manuel. Pour ce faire, ouvrez l'aide //via// //Système → Aide et soutien//, cliquez sur //Rubriques avancées// dans la colonne de gauche et enfin sur //Références des commandes du terminal (pages de manuel)//. Vous pouvez alors parcourir les pages de manuel par catégories. Vous les retrouverez aussi en effectuant une recherche dans toute la documentation, dans le menu //Édition → Rechercher//.

[[Firefox]] gère les URI du type ''%%man://<nom>%%'' et propose l'ouverture avec le navigateur d'aide GNOME. FIXME comportement KDE / Xfce -> peut-être général ?

==== Sous KDE (Kubuntu) ====

=== Konqueror ===

Konqueror gère des emplacements de la forme ''man:<nom>'' et les chemins directs tels ''man:/usr/share/man/fr/man1/man.1.gz''.

FIXME le reste

==== Sous Xfce (Xubuntu) ====

FIXME aussi yelp ou bien… ?

===== Consulter les pages de manuel sur internet =====
La plupart des pages de manuel sont aussi disponibles en ligne, sur divers sites dont voici une liste non exhaustive :
  * [[http://manpages.ubuntu.com/|manpages.ubuntu.com]]
  * [[http://manpages.debian.net/|manpages.debian.net]]
  * [[http://linux.die.net/man/|linux.die.net]]

===== Sources =====
  * ''man man''
  * Wikipedia [[wpfr>man (Unix)|fr]], [[wp>Man page|en]]

-----
//Contributeurs principaux : [[utilisateurs:Ban]] (création).//